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At least one drawing originally filed was informal and the print reproduced here is taken from a later filed formal copy. 
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PH c crrpi irr riiRF FOR A NON-VOIATILF SFMICONDUCTOR MEMORY 

FIFI P Cf TH F invention 

The present invention pertains to the field of the architecture of 

5 computer storage systems. More particularly, the present invention relates 
to a file storage systems for a large-block erasable non-volatile 
semiconductor memory. 
BACKSBQUMLQE thf invention 

Certain types of prior personal computer systems include a 

1 0 microprocessor (also referred to as a central processing unit) that Is 

coupled to several types of storage systems - - namefy, a read only memory 
("ROM"), a random access memory ("RAM"), a hard (he., fixed) disk drive 
for mass storage, and a floppy disk drive or drives for storage on removable 
magnetic floppy disks. The floppy disks are also referred to as diskettes. 

15 Those prior personal computer systems typically have an architecture that 
is especially geared to the storage systems that form a part of each of those 
prior personal computer systems. 

A ROM in conjunction with a program called a ROM monitor stored in 
the ROM is referred to as firmware. A ROM basic Input/output system 

20 ("BIOS") module is one type of ROM monitor that is stored in the ROM and 
used by the operating system for certain personal computers. The ROM 
BIOS module typically contains (1) drivers for certain hardware, including 
the keyboard, the disk drives, and the printer; (2) a power-on self-test 
program ("POST"); (3) a start-up routine that initializes the system; and (4) a 

25 loader program that reads the boot or first sector from a diskette or a hard 
disk. 

1 
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After the personal computer is turned on. the POST program of the 
BIOS module Is executed, the BIOS start-up routine performs certain 
initializations, and the loader program reads the contents of the boot sector 
from a diskette or from a hard disk. That boot sector contains a loader 
program of the operating system of the computer. That loader program of the 
operating system in turn loads part of the operating system from a diskette or 
a hard disk into RAM. 

The operating system for the personal computer processes 
commands, controls program execution, and oversees the hardware and 
software resources of the computer system. One type of prior art operating 
system is MS-DOS sold by Microsoft Corporation of Redmond, Washington. 
The MS-DOS operating system includes the loader program discussed 
above, the MS-DOS BIOS, an MS-DOS kernel, a user interface, and utility 
programs. 

15 The MS-DOS BIOS includes (1) new drivers that extend and use 

components of the drivers of the ROM BIOS; (2) an initialization routine for 
the MS-DOS BIOS drivers; and (3) another loader program. 

The new drivers of the MS-DOS BIOS are also referred to as BIOS " 
extensions or BIOS ROM extensions. In certain prior art personal 

20 computers, all input and output functions are driven by software contained 
in a 32 kilobyte or 64 kilobyte section of ROM and by. smaller (typically 2 
kilobyte) BIOS ROM extensions. 

The initialization routine for the MS-DOS BIOS drivers displays a 
copyright notice and adjusts the interrupt table for the new drivers. 



2 



The loader program of the MS-DOS BIOS loads the rest of the 
operating system. 

The MS-DOS kernel Is a shell between the BIOS and the application 
program. The MS-DOS kernel initiates application program execution, 
allocates .memory for the application programs, provides an application 
program interface between the application program and the hardware, and 
manages the reading and writing of the files. 

The user interface of MS-DOS provides information to the user. The 
user interface provides a prompt, which prompts the user to enter 
commands. The user interface acts as the manager of the system when the 
operating system is in control. 

The utility programs of MS-DOS provide certain useful functions for 
MS-DOS. Those functions include (1) formatting a diskette or a hard disk 
and (2) checking a diskette or a hard disk. 

The hard disk and diskettes used with the above-referenced personal 
computer system are non-volatile storage systems, which means that data is 
not lost when the power to the computer is turned off. The hard disk and 
diskettes are types of block storage devices, which means that data is 
transferred to and from them in blocks. 

On the hard disk and on the diskettes, data is physically stored on 
concentric tracks. Each track is made up of a plurality of sectors. A sector 
is typically fixed at 512 bytes in length. A disk controller and a physical 
device driver of a personal computer system typically always write to and 
read from disks in sector entities. 



A cluster is the smallest logically addressable storage unit. For some 
hard disks, there are four sectors per cluster. For some other hard disks and 
for a high density 3.5 inch diskette, a cluster is a single sector. 

Each partitioned area of a hard disk forms a logical subsystem that 
can contain its own operating system. A partition table in the first sector of a 
formatted hard disk contains information about the partitions. 

A hard disk and a diskette are formatted before first being used. Low- 
level formatting divides each track into sectors and places Identification 
("ID") sector headers at uniform positions around the track. A high-level 
formatting establishes the clusters, initializes some disk areas, and prepares 
the disk for receiving data. 

At the device driver and the BIOS level, disk requests are described 
by a 'tuple- that indicates the drive, the head, the cylinder/track, the sector, 
and the length. The logical sector numbers are known at the DOS level 
and BiOS level. DOS reads and writes to disks in cluster entities. 

Figure 1 shows the logical organization of a prior art MS-DOS 
operating system. For the MS-DOS operating system, a disk 2 is divided 
into two logical areas: a system area 4 and a data area 9. The system area 
contains a boot record 3. a file allocation table ("FATs") 5, and a root 
directory 7 that contains the root directory entries. The data area 9 contains 
files that are used to store application programs, data, and subdirectory 
information. 

The boot record 3 includes a bootstrap loader program for loading the 
operating system. The boot record 3 also includes information as to the 
ASCII name of the formatting DOS, the number of bytes per sector of the 



disk, the number of sectors per cluster, the number of sectors in the boot 
record, the number of copies of the file allocation table, the number of root 
directory entries, the number of sectors per partition, the disk type number, 
the number of sectors per file allocation table entry (or cluster), the number 
5 of sectors per track, the number of sides per disk, the number of reserved or 
hidden sectors, the physical drive number, an extended boot sector 
signature, a volume identification, and a volume table. 

The root directory 7 is a table of 32-byte entries that each set forth 
certain attributes of the file. Typically, each directory entry making up the 
1 o root directory 7 includes a file name, a file extension, attribute flags, time 
and date stamps for the file, the starting cluster number for the clusters that 
make up the file, and the file size. 

Each file on the disk is made up of one or more clusters. The file 
allocation table 5 contains a record in the form of a chain of how the clusters 
1 5 making up the file are finked together. A typical FAT 5 contains a list of 
two-byte entries, one for each cluster. For some prior FATs, the FAT 
entries are longer than two bytes. The length of each FAT entry depends 
upon the total number of clusters. The directory entry for a file contains the 
starting cluster number for the file, and the operating system uses that 
20 starting cluster number to access the file allocation table. Each FAT entry is 
a pointer to the next cluster of the file. Thus, the FAT entry retrieved by that 
first access contains the cluster number of the next cluster making up the 
file. The operating system uses that next cluster number to access the FAT 
to retrieve yet another cluster number, and continues this process until a 
25 special marker in FAT 5 is reached. 

5 



The file structure on the disk is tree-like. Entries in the root directory 
can be pointers to subdirectories. The subdirectories can be nested. 

One disadvantage associated with the use of hard disks and 
diskettes in certain types of prior personal computers is that hard disk drives 
5 and floppy disk drives are relatively physically large devices with a number 
of mechanical components. Such large sizes contrast with the small size of 
integrated circuits that make up many other parts of a personal computer. 
Moreover, the relatively large size of typical prior hard disk drives and 
floppy disk drives hinders portable personal computers from being even 
1 0 smaller and more portable. 

Another disadvantage associated with prior hard disk drives and 
floppy disk drives is that they consume a relatively large amount of power 
compared with the integrated circuits making up other parts of the personal 
computer. 

15 A further disadvantage associated with the prior hard disk drives and 

floppy disk drives is that they are prone to failure if exposed to excessive 
shock and vibration or to dust or other atmospheric contaminants. 

Another type of prior non-volatile computer memory is the flash 
electrically erasable programmable read-only memory ("flash EEPROM"). 

20 The flash EEPROM can be programmed by the user, and once 

programmed, the flash EEPROM retains its data until erased. Electrical 
erasure of the flash EEPROM erases the entire contents of the memory of 
the device in one relatively rapid operation. The flash EEPROM may then 
be programmed with new code. 
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One disadvantage of one type of prior flash EEPROM, however, is 
that each single bit cell cannot be overwritten from a logical zero to a logical 
one without a prior erasure. Another disadvantage of one prior type of flash 
EEPROM Is that it must be erased - - i.e., reset to a logical one state - - in 
5 large blocks or In a manner that erases the entire device. 

Another disadvantage of one prior type of flash EEPROM is that there 
is a finite limit on the number of erase and write cycles for the flash 
EEPROM before the flash EEPROM will fail. 

The limitations with respect to overwriting and erasure associated 
1 0 with certain prior flash EEPROMs have, in certain instances, limited the 
usefulness of flash EEPROMs in personal computer systems. 
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SUMMARY AND OBJECTS O F THE INVENTION 

One of the objects of the present invention is to provide a file 
f structure for a non-volatile semiconductor memory that is erasable only in 
blocks and that cannot have a bit overwritten from a first logical state to a 
5 second logical state without a prior erasure. 

Another of the objects of the present invention is to provide a file 
structure for a non-volatile semiconductor memory that is erasable only in 
blocks and that cannot have a bit overwritten from a first logical state to a 
second logical state without a prior erasure, wherein the non-volatile 
1 0 semiconductor memory includes a reserve block that helps to maximize the 
integrity and reliability of the file structure. 

Another of the objects of the present invention is to provide a 
computer system that includes a non-volatile semiconductor memory that is 
erasable only in blocks and that cannot have a bit overwritten from a first 
1 5 logical state to a second logical state without a prior erasure, wherein the 
non-volatile semiconductor memory comprises an active block, a reserve 
block, and a directory block. 

A non-volatile semiconductor memory that is erasable only in blocks 
is described. Each bit of the non-volatile semiconductor memory cannot be 
20 overwritten from a first logical state to a second logical state without a prior 
erasure. Each bit of the non-volatile semiconductor memory can be 
overwritten from a second logical state to a first logical state without a prior 
erasure. The non-volatile semiconductor memory comprises an active 
block for storing a first file, a reserve block for storing a second file, and a 
25 directoiy block. The second file is a copy of the first file. The copy is made 
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during a clean-up operation prior to erasure of the active block. The 
directory block comprises a directory entry for identifying the first file. 

Other objects, features, and advantages of the present invention will 
be apparent from the accompanying drawings and from the detailed 
5 description that follows below. 
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BRIEF DESCRIPTION n F TH p Qfi^^ 

The present Invention is illustrated by way of example and not 
limitation in the figures of the accompanying drawings, in which like 
references indicate similar elements, and in which: 

5 Figure 1 shows the logical organization of a prior art operating 

system. 

Figure 2 shows a personal computer system with a flash array and 
with a file system driver stored in the RAM of the computer system. 

Figure 3 illustrates a personal computer system that includes (1) a 
1 0 flash memory array, (2) a file system driver contained within the ROM BIOS 
and the ROM BIOS extension, and (3) a RAM buffer for transferring files and 
f for u P dat ' n 9 a directory of files. 

Figure 4 shows a personal computer system that includes a (1) flash 
memory array, (2) a file system driver stored in the ROM BIOS and the ROM 
!P!l!f| 15 BIOS extension, and (3) a separate system controller. 

Figure 5 shows a input/output mapped flash memory array. 
Figure 6 shows a paged mapped flash memory array structure. 
Figure 7 shows a direct memory mapped flash memory array 



structure. 
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Figure 8 shows a flash EEPROM with a variable file structure and a 
dynamic directory. 

Figure 9 shows the logical arrangement of an example of a linked-list 
directory. 

Figure 10 shows the physical location of an example of a linked-list 
25 directory. 
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Figure 1 1 shows a flash EEPROM with a variable file structure and a 
separate EEPROM for storing a directory. 

Figure 1 2 shows a flash EEPROM with a variable file structure and a 
separate EEPROM for storing a disk-analog directory. 

Figure 13 shows two directory/FAT entries. 

Figure 14 shows a flash EEPROM with a sectored file structure and a 
dynamic directory. 

Figure 15 shows a flash EEPROM with a sectored file structure and a 
separate EEPROM for storing a directory. 

Figure 16 shows a flash EEPROM with sectored file structure and a 
separate EEPROM for storing a disk-analog directory. 
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pFTAII FH DESCRIPTION 

Figure 2 shows a personal computer system 10 with one preferred file 
system or structure 32. The file system 32 includes one or more flash 
EEPROMs that form flash memory array 34. A flash EEPROM Is one type of 
semiconductor memory. File structure 32 also Includes a software file 
system driver 28 that is stored in system RAM 22. Personal computer 
system 10 also includes central processing unit ("CPU") 12 and bus 18. 

As described in more detail below, flash memory array 34 is 
structured to allow dynamic memory reallocation. Flash memory array 34 
has either a yariable file structure or a sectored file structure. Either a 
linked-list directory or a disk analog directory is used in conjunction with 
flash memory array 34. The disk analog directory resides in a separate 
memory, such as a byte-erasable EEPROM. The linked-list directory either 
resides on the flash memory or on a separate memory, such as a 
byte-erasable EEPROM. 

System RAM 22 includes space for storage of application program 
24. In one embodiment of the present invention, system RAM 22 is one 
megabyte incize. System RAM 22 also includes space for the storage of 
other application programs and for data. In one embodiment of the present 
invention, system RAM 22 includes one operating system 26 for computer 
system 10. In alternative embodiments, system RAM 22 further includes two 
or more operating systems. 

System RAM 22 also includes file system driver software 28. The file 
system driver software 28 defines the file structure for flash memory array 
34. In personal computer system 10, central processing unit 12 executes 
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the foreground-task software routines of file system driver software 28 in 
order to handle all file system management utilities for flash memory array 
34. The file system driver 28 and the file structure for a flash memory array 
are discussed in more detail below. 

Not only does RAM 22 store application program 24. operating 
system 26. and file driver 28. but application program 24, operating system 
26, and file driver 28 are also stored In flash memory array 34 during the 
times that computer 1 0 is either off or on. Flash memory anay 34 can store 
more than one application program, more than one operating system, and 
more than one file driver. Flash memory array 34 also stores data files and 
directory information. Upon either a warm boot or a cold boot, the file 
system software driver 28 is loaded into system RAM 22 from flash memory 
array 34. In short, flash memory array acts as a mass storage device that 
replaces a hard disk. 

Computer system 10 also includes ROM 14. which stores BIOS 
software for computer 10. In one embodiment of the present invention, the 
BIOS stored In ROM 14 includes both a 64 kilobyte BIOS with additional 
BIOS ROM extensions of two kilobytes each. The file system software 
driver 28 is stored prior to execution in flash memory array 34 rather than in 
ROM 14. 

Upon execution of ROM BIOS program 14 after power-up of computer 
10, file driver 28 and operating system 26 are loaded into system RAM 22 
from flash memory array 34 via bus 18. The user of computer 10 then uses 
operating system 26 to load application program 24 into RAM 22. The user 
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of computer 10 can also load data, other application programs, and other 
operating systems into system RAM 22. 

In one embodiment of the present invention, flash memory array 34 is 
erased In blocks, wherein each block comprises a large number of bits. In 
an alternative embodiment, flash memory array 34 is erased in Hs entirety. 

Flash memories differ from conventional electrically erasable 
programmable read only memories CEEPROMs") with respect to erasure. 
Conventional EEPROMs use a select transistor for individual byte erase 
control. Flash memories, on the other hand, achieve much higher density 
with single transistor cells. During the erase mode, a high voltage is 
supplied to the sources of every memory cell in a block or in the entire chip 
simultaneously. This results In a full array or a full block erasure. 

For flash memory array 34, a logical "one" means that few if any 
electrons are stored on a floating gate associated with a bit ceil. A logical 
-zero- means that many electrons are stored on the floating gate associated 
with the bit cell. After flash memory array 23 has been erased, a logical one 
Is stored in each bit cell of flash memory array 23. Each single bit cell of 
flash memory array 23 cannot be overwritten from a logical zero to a logical 
one without a prior erasure. Each single bit cell of flash memory array 23 
can, however, be overwritten from a logical one to a logical zero, given that 
this entails simply adding electrons to a floating gate that contains the 
intrinsic number of electrons associated with the erased state. 

Flash memory array 34 can be programmed in one of three ways: (1) 
a single bit at a time, (2) a single word at a time, or (3) groups of words at a 
time. A word consists of a plurality of memory bits associated with a single 
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memoiy system address or a single device. The groups of words 
programmed at a time can be as large as an erase block of flash memory 
array 34. Program operations with respect to flash memories are also 
referred to as write operations. 
5 As discussed above, each bit of flash memory array 34 cannot be 

overwritten from a logical zero state to a logical one state without a prior 
erasure. This necessity for erasure prior to overwriting from a logical to a 
logical one introduces a functional operation associated with a flash 
memory. 

1 0 Flash memory array 34 stores both executable code and 

non-executable data. In the detailed description that follows, the generic 
term "data" is used to refer to either (1) non-executable data alone or (2) 
both executable code and non-executable data. 

The .read operation associated with flash memory array 34 closely 
1 5 resembles the read operation associated with other read-only memory 
devices. In one embodiment, a read operation for flash memory array 34 
takes on the order of 135 nanoseconds. Write and erase operations for 
flash memory array 34 are, however, significantly slower. In one 
embodiment of the present invention, erase times for a block of flash memory 
20 array 34 are on the order of one second. Write operations for a single word 
of flash memory array 34 take on the order of 10 microseconds. Thus, the 
read write and erase operations associated with flash memory array 34 
have an asymmetrical nature - - the write and erase operations are 
significantly slower than the read operations. 
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In addition, each flash memory of flash memory array 34 has a finite 
endurance lifetime with respect to erase plus write (i.e., program) 
operations. For example, in one embodiment, flash memory array 34 can 
withstand a minimum of 10,000 erase/program cycles before flash memory 
5 array 34 begins to fail or exhibits erase/write performance degradation. 
Thus, in one embodiment of the present invention, there is a limit as to the 
number of erase/write cycles that flash array 34 can be put through. On the 
other hand, there is no such maximum lifetime with respect to the number of 
times flash memory array 34 can be read from. 

10 In one embodiment of the the present invention, each flash memory 

device comprising flash memory array 34 has multiple erase blocks within 
each memory device. For that embodiment, there are restrictions on the 
erase/programming cycling of adjacent blocks. Adjacent blocks are blocks 
that share either common row connections or common column connections. 

1 5 The restrictions on the cycling of adjacent blocks are made to prevent 
electrical data disturb conditions. 

A more frequently cycled block is referred to a hot block. A block 
that is not cycled or is cycled less frequently is referred to as a cold block. 
The important parameter is the difference between the number of cycles 

20 associated respectively with adjacent blocks. A hot block can eventually 
reach a cycle count such that data is adversely affected in a cold block of 
flash array 34. One way to avoid this hot block/cold block interaction is to 
place cycle restrictions on hot blocks of flash array 34. Another way to 
minimize the adverse effects of hot block/cold block interaction is to 

25 periodically erase and reprogram the cold blocks of flash array 34. The 
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periodic erase and reprogramming of cofd blocks is referred to as the 
refreshing of cold-blocks. 

As described in more detail below, the preferred file structures of the 
present invention take into account the above-referenced functional 
5 characteristics of the flash EEPROMs that make up flash array 34. 

Figure 3 shows personal computer system 40 with one preferred file 
structure 58. Personal computer system 40 includes central processing unit 
12 and ROM 42. ROM 42 stores BIOS software 43 and BIOS extension 
software 44. Personal computer system 40 also includes bus 48 and system 
10 RAM 52. System RAM 52 stores application program 24 and operating 
system 26. Personal computer system 40 also includes RAM buffer 62 and 
flash memory array 64. 

RAM buffer 62 provides buffering for the transferring of files between 
flash memory array 64 and system RAM 52. RAM buffer 62 also provides 
1 5 buffering for the construction of or the updating of a directory for the files 
stored in flash memory array 64. 

One or more flash EEPROMs make up flash memory array 64. Flash 
memory array 64 stores application program 24, operating system 26* data, 
other application programs, and other operating systems. Operating system 
20 26, application program 24, and other programs and data can be transferred 
to system RAM 52 from flash memory array 64 via bus 48. 

File structure 58 includes flash memory array 64, RAM buffer 62, 
ROM BIOS extension software 44, and a portion of ROM BIOS software 43. 
The file system driver software that defines the file structure for flash 
25 memory array 64 forms part of ROM BIOS software 43 and ROM BIOS 
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extension software 44 in ROM 42. In the embodiment shown in Figure 3, the 
file system driver is part of and integral to the firmware of personal computer 
system 40. BIOS 43 and BIOS extension 44 are memory blocks that are 
either direct-mapped or paged. Therefore, in the embodiment shown in 
Figure 2, the file system driver software is neither stored in system RAM 52 
nor stored in the flash memory array 64. 

Figure 4 illustrates a personal computer system 70 with yet another 
preferred file structure 94. Personal computer system 70 includes a central 
processing unit 12 and system RAM 72. In one preferred embodiment, 
system RAM 72 includes an application program 24 and an operating 
system 26. Personal computer system 70 also includes a bus 88 and a 
ROM 78. ROM 78 includes BIOS software 79 and BIOS extension software 
80. 

Personal computer system 70 also includes controller 92 and flash 
memory array 96. Flash memory array 96 Is comprised of flash EEPROMs. 
Flash memory array 96 stores application program 24, operating system 26. 
data, other application programs, and other operating systems, which can 
be loaded into system RAM 72 via bus 88. 

File structure 94 is comprised of controller 92, flash memory array 96, 
ROM BIOS extension 80, and a portion of ROM BIOS 79. 

Personal computer system 70 shown in Figure 4 has a fully hardware 
driven file structure for flash memory array 96. Controller 92 is specifically 
dedicated to defining and controlling the file structure for flash memory array 
96. Controller 92 includes a microcontroller 100 for overseeing control. 
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Controller 92 also includes control logic 106. In one preferred 
embodiment of the present invention, control logic 106 comprises a 
programmable logic array ("PLA"). Logic circuitry 106 contains the digital 
logic that controls the operation of controller 92. 

In one embodiment, controller 92 includes ROM 98 that stores file 
system driver software. The file system driver software is executable by 
microcontroller 100 and defines the file structure for flash memory array 96. 

In an alternative embodiment, file system driver software that is 
executable and defines the file structure for flash memory array 96 forms 
part of ROM BIOS software 79 and BIOS ROM extension software 80. 

Controller 92 includes buffer RAM 102. Buffer RAM 102 provides 
buffering for the transferring of files and for the creation and updating of 
directories. 

Controller 92 also includes buffer/multiplexer 104. Buffer/multiplexer 
104 provides buffering for the transferring of files. Buffer/multiplexer 104 
also multiplexes data passed to and from flash memory array 96. 

The logic associated with logic buffer/multiplexer circuit 104 can 
conform to any standard system bus Interface. For example, the logic 
associated with buffer/multiplexer 104 can conform to one or more of the 
following standards: PC XT, PC AT (i.e., IDE - - Industry Standard 
Architecture), EISA (i.e., Extended Industry Standard Architecture). MCA 
(i.e., MicroChannel Architecture), VME (i.e., Virtual Machine Environment), 
and Multibus. 
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In one embodiment of the Invention, controller 92 is contained within 
personal computer system 70. For example, controller 92 could reside on a 
system board (not shown) within personal computer 70. 

In an alternative embodiment, controller 92 can be an input/output 
("I/O") device that resides external to personal computer system 70 or within 
an expansion slot (not shown) of personal computer system 70. For that 
alternative embodiment, the logic associated with buffer/multiplexer 104 can 
conform to any standard I/O interface. For example, buffer/multiplexer 104 
can conform to one or more of the following I/O interfaces: IDE ST506 
SCSI (i.e., Small Computer System Interface), and SA400 (i.e.. a floppy disk 
standard). Thus, for that alternative embodiment, personal computer 70 
would communicate with controller 92 by way of one of those standard I/O 
interfaces. 

Personal computer system 40 of Figure 3 and personal computer 
system 70 of Figure 4 each include hardware that is dedicated to controlling 
the file structure of the respective flash memory array. For personal 
computer system 40. that additional hardware is RAM buffer 62. For 
personal computer system 70. that additional hardware is controller 92. 
RAM buffer 62 of Figure 3 and controller 92 of Figure 4 provide means for 
avoiding the necessity for storing file system control code in system RAM 
52. flash memory array 64. system RAM 72. or flash memory array 96. 
respectively. 

RAM buffer 62 and controller 92 each also serve to buffer data, so 
that system RAM 52 of Figure 3 and system RAM 72 of Figure 4 need not 
act as data buffers for file structures 58 and 94. respectively. Moreover, the 
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inclusion of data buffer 62 in personal computer system 40 and controller 92 
in personal computer system 70 means that system RAM 52 and system 
RAM 72 need not act as scratch pad areas for the file structures for flash 
memory arrays 64 and 96, respectively. 
5 RAM buffer 62 of Figure 3 and controller 92 of Figure 4 allow file 

structure 58 and file structure 96 to each be recognized as containing a 
bootable storage area that is part of the basic system hardware for the 
respective personal computer system. The result is that RAM buffer 62 and 
controller 92 serve to improve the overall performance of the file structures 
1 0 of the flash memory arrays for the respective personal computer systems. 

The different configurations of personal computers 10, 40, and 70 
shown in Figures 2-4 result in different characteristics of the computers. In 
. the computer system 10 of Figure 2, file driver 28 is executed by central 

processing unit 12 as a foreground-task software routine that handles all the 
15 file management utilities for managing flash array 34. File system driver 28 
takes up a portion of system RAM 22, but the size of system RAM 22 might 
be limited. For example, if operating system 26 of personal computer system 
10 is MS-DOS, then system RAM 22 may be limited to one megabyte of 
"real mode" space. 

20 For computer system 40 of Figure 3, the file system driver software 

that defines the file structure for flash memory array 64 forms part of ROM 
BIOS software 43 and ROM BIOS extension software 44 in ROM 42. The 
amount of storage space in ROM 42 may be limited, however. For example, 
in certain MS-DOS compatible personal computers, all input-output 

25 functions are driven by firmware contained in a 64 kilobyte BIOS section of 
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ROM with smaller BIOS ROM extensions ol .wo kilobytes each. The file 
system driver software might exceed the space available in ROM 42 if ROM 
42 is small in size. 

In contrast, hardware controller 92 for computer system 70 stores the 
file driver, and this reduces the memo* requirements with respect to flash 
array 96, ROM 78. and system RAM 72. Moreover, hardware controller 92 
simplifies the file system control commands. For example, hardware 
controller 92 converts the file system control commands to high level 
procedure calls that are software accessible by a label referring ,o code 
residing in some other memory space. In one embodiment of the present 
Invention, the simplified file system control commands or file driver control 
commands are stored in ROM 98 of hardware controller 92 as conventional 
BIOS-type control code. This in turn allows the solid-state file system 94 to 
be recognized as a basic bootable device. This results in simplified file 
system calls. Each file system call results in the execution of the file system 
driver (which is also referred to as the file system control code). 

In one embodiment, each file system call for a computer system 70 of 
Figure 4 is executed directly by CPU 12 fetching instructions from the main 
BIOS and direct-mapped BIOS extensions stored in ROM 78. In another 
embodiment, each file system call is executed by CPU 12 from memory 
pages residing at BIOS extension memory blocks stored in ROM 98. In yet 
another embodiment, each file system call is executed by microcontroller 
100 from the file system driver stored in ROM 98 of hardware controller 92. 

In a preferred embodiment, hardware controller 92 reduces each file 
related task to a single command from the host CPU 12. which helps to 
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increase the off loading of the host CPU 12. Controller 92 accepts incoming 
data at RAM type memory speeds by holding the incoming data in local 
RAM buffer space 102. Hardware controller 92 completes each given task 
automatically, but only handles one operation at a time. 

In addition, controller 92 allows host CPU 12 to Interrupt any file 
system task for a immediate data access. This requires the additional RAM 
buffering of any valid file information that might otherwise reside in an 
inaccessible block. An inaccessible block is one involved with a write or 
an erase operation. The controller 92 resumes the original task following 
the interrupt.' In one embodiment of the present invention, control hardware 
92 cues up a given number of simultaneous write tasks. 

Furthermore, in one embodiment, controller 92 continuously monitors 
the main flash memory storage array 96 for available free space and 
hot/cold block cycle imbalances. Hardware controller 92 also 
automatically initiates a redistribution operation with respect to flash memoiy 
96 as needed. A redistribution operation evens out the cycling among 
blocks of flash memory array 96. The redistribution operation is 
automatically initiated by hardware controller 92 as needed in a fully 
background-task fashion. 

Hardware controller 92 also automatically Initiates a clean-up 
operation with respect to flash memory array 96 In order to free space for 
storage in flash memory 96. The clean-up operation is initiated by hardware 
controller 92 as needed and is done in a fully background-task fashion. 
The clean-up operation is described in more detail below. 
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In order for file system control hardware 92 to continuously monitor 
flash memory array 96 for available free space and hot/cold block cycle 
imbalances, and for controller 92 automatic initiate clean-up or 
redistribution operations, flash memory 96 should either (1) be resident as a 
5 storage device wtthin personal computer system 70 or. attentively. (2) be 
securely physically interlocked to personal computer system 70 if flash 
memory array 96 is removable. For the alternative embodiment wherein 
flash memory array 96 is removable, persona, computer system 70 includes 
an indicator light-emitting diode ("LED") that is lit when a background task 
0 involving flash memory array 96 is occurring. The user of personal 
computer 70 is instructed not to remove flash memory array 96 when the 
LED is fit and. accordingly, when a background task is occurring. 

In preferred embodiments, the interface circuitry to a main flash 
memory array can be either (1) input/output ("I/O") mapped. (2) paged 
5 memory mapped, or (3) direct memory mapped. Figure 5 illustrates a I/O 
mapping scheme for the interface circuitry. 

It is to be appreciated that for the embodiments shown in Figures 2-4 
flash memory arrays 34. 64. and 96 could be used to replace either fixed ' 
disk drives or floppy disk drives. 

The I/O mapping scheme shown in Figure 5 uses an VO plane 85 
comprising serial transfer I/O ports that maps to flash memory array 81 and 
local buffer RAM 83. Because the the VO mapping scheme shown in Rgure 
5 uses the separate I/O memory piane 85 instead of a main memory plane 
(main memory is also referred to as system RAM), the I/O mapping scheme 
shown in Figure 5 consumes none of the host computer's main memory 
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space - - that is. the I/O mapping scheme consumes none of the host 
computer's system RAM. 

The I/O devices coupled to serial transfer I/O ports 85 cannot, 
however, support direct execution by a central processing unit given that 
5 those I/O devices (not shown) are serial rather than random access 
devices. Those I/O devices must download code files to system RAM for 
execution. 

Figure 6 illustrates a paged memory mapped interface to a paged 
map flash memoiy array 105. Figure 6 shows main memory plane 89. Main 
1 0 memory plane 89 includes main system RAM 99. paging window 97. 
BIOS/ROM extension 95. BIOS 93. and expansion system RAM 91. 

In one embodiment of the present invention, main memory plane 89 
has a one megabyte address range constraint 101. The one megabyte 
address range constraint for main memory plane 89 means that the 
15 protected mode of a CPU or microprocessor is used to address portions of 
main memoiy plane 89 above the one megabyte address constraint 101. In 
other words, the protected mode of a CPU is used to address the expansion 
system RAM area 91 of main memoiy plane 89. 

Typical early generation and low performance microprocessors did 
20 not include a protected mode. Moreover, typical early generation and low 
performance operating systems for personal computing systems did not 
have the capability for handling protected mode addressing. Therefore, 
those low performance microprocessors and operating systems could not 
address the areas above the one megabyte address. Nevertheless, certain 
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high performance and later generation microprocessors and operating 
systems can address areas above the one megabyte address. 

In Figure 6, flash memoiy array 105 is comprised of smaii pages 107, 
109, and 111 and flash memory array 105 is coupled to local buffer RAM 
113. In an alternative embodiment of the present invention, flash memory 
array 105 could be comprised of any number of pages. 

In Figure 6. paging window 97 is the paged memory mapped 
interface that allows direct host central processing unit access to pages 
107, 109, and 111 of flash memory array 105. Each page is changed to 
point to a different flash memory array 105 segment as needed. 

Figure 6 also shows paged firmware 103 that is used as an 
expansion for a device driver. Paged firmware 103 includes pages 115, 
117, 119, and 121. In one embodiment of the present invention, paging 
window interface 97 is used to point to paged firmware 103. Having paging 
window 97 point to paged firmware 103 allows expansion to the larger 
firmware storage space 103. This gives the computer system additional 
storage space beyond a single (typically 2 kilobyte) BIOS/ROM extension 
location 95. 

Figure 7 illustrates a direct memoiy mapped interface to a main flash 
memory array. In Figure 7, main memory plane 135 includes flash memory 
array map 149 and local buffer RAM 147 in addition to main system RAM 
137, BIOS/ROM extension 139, BIOS 141, and expansion system RAM 
. 145. 

The main memory plane 135 shown in Figure 7 has a one megabyte 
address range constraint 143. Flash memory array map 149 and local 
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buffer RAM map 147 reside above the 1 megabyte address range constraint 
143 of memory plane 135. This means that a protected mode of a CPU or 
microprocessor is used to address flash memory array map 149 and local 
buffer RAM map 147. In contrast, the CPU can address the main system 
RAM 137, the BIOS/ROM extension 139, and the BIOS 141 of main memory 
plane 135 without using the protected mode. 

Flash memory array map 149 directly maps to the flash memory array 
of the personal computer system. Therefore, the flash memory array map 
149 is equal in size to the flash memory storage array of the personal 

computer system. 

Moreover, the local buffer RAM map 147 is directly mapped to the 
local buffer RAM of the personal computer system. It follows that the local 
buffer RAM map 1 47 is equal in size to the local buffer RAM of the personal 

computer system. 

The direct memory mapped scheme thus employs a large amount of 
main memory space. In addition, the direct memory mapped method 
requires a CPU and operating system capable of addressing portions of the 
main memory plane above the 1 megabyte address range constraint 143. 

The direct mapped scheme allows direct code execution from all of 
the flash memory array. On the other hand, the paged mapped scheme 
allows direct code execution from a portion of the flash memory array. 

The direct mapped scheme requires a CPU and operating system 
capable of addressing beyond the one megabyte constraint. In contrast, 
the paged mapped scheme works with a CPU and operating system 
incapable of addressing beyond the one megabyte constraint. 
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Figures 8, 11, 12 and 14 through 16 show examples of preferred file 
structures for the flash memory EPROM array of a persona! computer 
system. In particular, Figures 8, 11, 12, and 14 through 16 illustrate 
preferred file structures for flash arrays 34, 64, and 96 of personal computer 
5 systems 10, 40, and 70, respectively, of Figures 2 through 4. The file 
structures shown In Figures 8, 11, and 12 are variable file structures. The 
file structures shown In Figures 14 through 16 are sectored file structures. 
The file structures shown in Figures 8 and 14 each include a dynamic file 
directory, which resides within the flash memory array. The file structures 

4 

10 shown in Figures 11, 12, 15 and 16 each include a file directory that Is 
stored in a separate EEPROM or static RAM ("SRAM"). The file structures 
shown in Figures 8, 11, 14, and 15 include linked-fist directory entries. The 
file structures shown in Figures 12 and 16 each include a file directory that 
is analogous to the directory used for prior hard or fixed disks. Variable 

1 5 files, sectored files, dynamic directories, separately-stored directories, 
linked list directories, and disk-analog directories are discussed in more 
detail below. The file structures shown in Figures 8, 11, 12 and 14 through 
16 are each shown in state immediately following a clean-up operation. 
Figure 8 shows file structure 1 10 of flash memory array 112. File 

20 structure 1 10 is a variable-sized file structure. The variable sized file 
structure is also referred to as a variable file structure. 

In a variable file structure such as file structure 110, code or data is 
stored contiguously so that a program counter of a CPU of a personal 
computer can step through the code or data. The variable file structure thus 

25 allows execution in place. Execution in place means that the CPU can 



execute code directly from a flash memory array without the need for RAM. 
Execution in place is also referred to as direct or in-place code execution. 

The variable file structure of file structure 110 allows code files to be 
stored contiguously regardless of size for direct execution in place 
operation. Execution in place operation eliminates the time required to 
download to RAM-type memory for execution. The use of a variable file 
structure for flash memory thus reduces the RAM requirements for the 
personal computer system. This in turn reduces the system power draw of 
the extra RAM that would otherwise be required. 

When file structure 110 is properly formatted, there are no hot or cold 
blocks, except for headers residing in the main array. This means that there 
is no need to keep track of the erase/programming cycling of adjacent 
blocks to prevent electrical data disturb conditions. 

On the other hand, a variable file structure for a flash memory array is 
substantially different from the sector-based file structure found on atypical 
prior disk drive. Typical prior art operating systems for personal computers 
are designed to work with a disk sectored file structure only. Therefore, 
present typical high level operating system software would have to be 
modified or added to in order to work with a variable file structure. 

In addition, for a variable file structure the file clean-up operation 
(described in more detail below) for the reallocation of file storage space is 
less efficient and more frequent than for a sectored file structure. Thus, with 
a variable file structure, the clean-up operations take up more background 
time. Moreover, a variable file structure requires more overall flash memory 
erase/write cycling. 
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Flash memory array 112 includes a number of data blocks for storing 
code or data. Figure 8 illustrates an example of the file structure of flash 
memory array 1 12 in the state immediately following a clean-up operation. 

Blocks 114, 116, and 118 in flash memory array 112 are 
to-be-reserved" blocks, also referred to as reserve blocks or reserved 
blocks. Reserve blocks are blocks that provide temporary file back-up 
during a clean-up operation. A clean-up operation is used for reallocation. 
A clean-up operation involves first moving all currently active files out of 
blocks that will eventually be erased. Each flash memory block can be 
erased all at once. The reserved blocks 114, 116, and 118 thus are 
available for erase/reallocation during a clean-up operation. 
To-be-reserved blocks 1 14, 1 16, and 1 18 thus provide temporary file 
backup. 

In one embodiment, at least one of the reserved blocks is used as a 
spare reserved block. This spare block helps to ensure that a reserved 
block is available for clean-up operations, which in turn helps to improve 
file system reliability. 

As shown in Figure 8, block 120 is a to-be-free block. 

Blocks 122, 124, 126, and 128 are free blocks. Free data blocks 
122. 124, 126, and 128 are usable blocks for storing code and data. Free 
blocks 122. 124, 126, and 128 of Figure 8 are not active blocks, but instead 
are blocks that can be used for storing code or data. 

During the operation of the personal computer system, data or code 
is placed in the free blocks. Data block 130 is a partially free block. A 
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portion of block 130 contains active code or data. The rest of block 130 is 
partially free and available for future storage of code or data. 

As free and partially free blocks are filled with code and data, the 
number of blocks that remain free of data or code diminishes. When the 
number of free, usable blocks reaches the allowed number of reserve 
blocks, a clean-up operation is initiated. 

Blocks 132, 136, 138, 140, 142, and 144 together with a portion of 
block 130 comprise the active and deleted contiguous variable sized files. 
In one embodiment, blocks 132, 136, 138, 140. 142. and 144 together with 
a portion of block 130 also include the active and deleted subdirectories. 

Files 150. 164. 166, 168, 170. 172, and 174 are the deleted files 
within blocks 132. 136. 138. 140, 142, and 144. The deleted files 150, 164. 
166, 168, 170. 172. and 174 shown In Figure 8 are files that had been 
deleted by the user. 

During a clean-up operation, the oldest of the active files are 
rewritten into blocks 114 and 116. For the file structure 110 shown in Figure 
8. blocks 138. 140. 142. and 144 contain the oldest active and deleted 
contiguous variable files. The active files found in blocks 138. 140. 142, 
and 144 are the files to be rewritten into blocks 1 14 and 1 16. A 
compression operation occurs during the clean-up operation so that the 
four blocks 138. 140. 142. and 144 can fit into the two reserve blocks 114 
and 116. During the compression operation, files previously deleted by the 
user are not rewritten into blocks 114 and 116. In Figure 8. files 168, 170. 
172, and 174 are the deleted files found in blocks 138, 140. 142, and 144. 
Those deleted files 168. 170, 172. and 174 are therefore not rewritten into 
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blocks 114 and 116. Blocks 138, 140, 142, and 144 are said to reside in 
the next area to be compressed. The amount of compressible space is the 
amount of space taken up by the deleted files 168, 170. 172, and 174. 

Blocks 114, 116, 118, and 120 are the blocks that resulted from a 
prior clean-up operation. Blocks 114, 116, 118, and 120 are therefore said 
to comprise the compressed space that resulted from the last clean-up 
operation. 

The clean-up process for variable file structures, such as the file 
structure shown in Figure 8, is circular in fashion. Reserve blocks are in 
consecutive order except when the reserve blocks loop around from the 
physical top of flash memory array i 1 2 to the physical bottom of flash 
memory array 1 12. As stated above, when the number of free usable blocks 
reaches the allowed number of reserve blocks, the clean-up operation is 
initiated. The oldest blocks containing active and deleted files are 
compressed and cleaned-up first. The oldest blocks containing active and 
deleted contiguous variable files are found directly after the reserve blocks 
within flash memory 1 12. The number of blocks to be rewritten and 
compressed as part of a clean-up operation is determined by the number of 
deleted files wfthin those blocks. In other words, the compressible space 
within the oldest blocks determines how many of those blocks will be 
rewritten as part of any one clean-up operation. For example, blocks 138, 
140. 142, and 144 contain sufficiently large deleted files to allow the four 
blocks 138, 140. 142, and 144 to be compressed into the two blocks 114 
and 116. 
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After blocks 138. 140, 142, and 144 are compressed into blocks 114 
and 1 16 then blocks 138, 140, 142, and 144 are erased. After erasure of 
blocks 138, 140, 142, and 144, blocks 138, 140, and 142 become reserve 
blocks and block 144 becomes a free block. 

5 File structure 110 shown In Figure 8 Includes a directory that stores 

the attributes and locations of the files within flash memory array 112. For 
file structure 1 10, ail the directory Information is stored within block 134 of 
flash memory array 112. The directory for file structure 110 is thus referred 
to as a flash memory based directory. 

10 The directory of file structure 1 10 requires dynamic directory 

relocation. Dynamic directory relocation means that the file system moves 
the directory to various location within flash memory array 112 by write and 
erase operations. For the example shown in Figure 8, the directory 
occupies block 134 of flash memory array 112. Nevertheless, at various 

15 points in time, the directory could occupy any of the other blocks of flash 
memory array 112, including blocks 114, 116, 118. 120. 122. etc. 

For the particular point in time shown in Figure 8, the directory 
resides in block 134. Block 134 contains the directory flag 152. the boot 
record 154, the block status table 156 (which is also referred to as BST 

20 156), the linked-list directory entries 158, and free directory space 160. 
Block 134 is referred to as the directory block. 

Directory flag 152 stores a pattern of data that indicates which block 
stores the root directory for file structure 110. In one embodiment of the 
present invention, directory flag 152 stores a unique non-random data. 

25 pattern that indicates that the block containing directory flag 152 is also the 
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block containing the root directory. For example, in one embodiment, 
directory flag 152 stores a series of repeating AAh/55h data. In another 
embodiment, directory flag 152 stores some other non-random sequence of 
data. 

5 In one embodiment of the present invention, a supplemental check is 

done to determine if a particular block is in fact the directory block. This is 
done to help avoid an error in locating the directory block that might 
otherwise occur if a block other than the directory block had a beginning 
pattern of data matching the pattern of data of directory flag 152. The 

1 0 supplemental check is done by checking a checksum data field residing in 
boot record 154 of directory block 134. In one embodiment, the checksum 
data field in boot record 154 is a particular pattern chosen because that 
pattern of data does not change if boot record 154 is both valid and current. 
In another embodiment, the checksum data field in boot record 154 is a 

1 5 dedicated cycle redundancy check fCRC") or error correction code 
("ECC") data field. First, the computer system would look for the directory 
flag. Then the computer system would check the checksum data field. A 
correct result from the checking of the checksum data field in boot record 
1 54 would tell the computer system that it had in fact found the current valid 

20 directory block for flash memory array 112. 

In one embodiment of the present invention, the logical one values of 
the checksum data field of boot record 154 would be overwritten to logical 
zero values when boot record 154 becomes no longer valid or no longer 
current. 
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Boot record 154 resides within block 134 next to directory flag 152. 
Boot record 154 contains information as to the particular file system type 
and the particular file system revision. Boot record 156 also contains 
certain file system parameters. Those parameters Include formattable 
capacity Information, reserved block Information, appended directory 
Information, information relating to the old directory, and information relating 

to the root directory. 

The formattable capacity information is the size of the area of flash 
memory array 112 that can be formatted to store code and data. The 
reserved block information identifies which blocks are the reserved blocks. 
As discussed above, the reserved blocks are blocks used during clean-up 
and reallocation operations. The appended directory information is the 
location of any additional blocks that are being used for storage of 
additional directory information. An appended directory stored In one or 
more additional blocks would be necessary if the number of files stored 
within flash memory array 112 exceeds a certain amount. The old directory 
is a backup copy of the current directory. The parameter information 
relating to the old directory is the location within flash memory array 112 
where that old directory is being stored. For example, in Figure 8 the old 
directory is stored in block 114. The root directory Is the first directory entry. 
The parameter information relating to the root directory is the location within 
flash memory array 112 of the root directory. 

Block status table 156 contains information as to which blocks are 
active blocks, which blocks are reserve blocks, and which blocks are 
defective or failed blocks. In one embodiment, block status table 156 also 
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contains cycle count information with respect to each block. The cycle 
count information indicates how many times a block has been erased and 
rewritten to. Block status table 156 resides within block 134 next to boot 
record 154. 

5 Linked list directory entries 158 is also referred to as main directory 

158. Main directory 158 resides within blocks 134 next to block status table 
156. 

Main directory 158 contains a series of individual directory entries. 
Each directory entry contains information as to directory entry type - - 
1 0 namely, whether the directory entry (1 ) is for a file or (2) is a pointer to a 
subdirectory. 

Each directory file entry includes information as to the file 
name/extension, the date, the time, the file type, the file length, the physical 
file address within flash memory array 1 12, a sibling pointer, and a child 
1 5 pointer. 

In one embodiment of the present invention, the file name/extension 
are ten bytes that identify the file for the user. In that embodiment, the file 
name/extension can be words, numbers, and letters. 

The date and time information within the file entry specify the date 
20 and time the file was either created or last revised or saved. 

The file type information identifies whether the file comprises code, 
paged code, data, or data append segments. 

The file length information identifies the physical size of the file or 
segment. 
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The physical file address information identifies the location within 
flash memory array 1 1 2 of the file or segment. 

The sibling and child pointers comprise the linked-list directory 
hierarchy. In other words, the sibling and child pointers comprise the 
5 directory structural tree. 

Each pointer points to the location of another directory entry. In one 
embodiment of the present invention, the pointer is an absolute physical 
address within flash memory array 112 of the directory entry pointed to. In 
other embodiment of the invention, however, each pointer consists of an 
10 offset address that represents an incremental address within the block or 
[j.'. j blocks that store the directory. 

£ • , j An example of a pointer that consists of an absolute physical address 

|- . " ' . . • £ 

T I is 1264FFFF in hexadecimal. On the other hand, an example of a pointer 

• .■ - ■*? 

!ll!lt!!i!i!l!| that consists of an offset address is FOF in hexadecimal. The offset address 

15 of a pointer is also referred to as an index address. 

The embodiment that uses the index approach for pointers minimizes 
pointer size. The index approach also avoids the necessity of recalculating 
each pointer address after the directory has been relocated after a clean-up 
operation. 

20 If a single block of flash memory array 1 12 is insufficient to contain 

the entire directory, the root directory can point to a secondary appended 
directory block or to more than one secondary appended directory block. If 
one or more appended directory blocks are used, then each "index-style" 
pointer would include an index for determining which one of the directory 
25 blocks the directory entry pointer is referring to. 
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In one embodiment of the present invention, the pointer index 
address size is further minimized by requiring all directory entries to be of a 
common length, wherein the common length corresponds to an offset 
address increment referred to by the index. 

The directory entries 158 form a linked-list Starting with the root 
directory entry, the entire file system directory tree 158 is built from the 
link-list chaining of directory entries through the use of sibling and child 
pointers. An example of a linked-list directory tree is shown in Figures 9 
and 10. In Figures 9 and 10 the directory entries are as follows: root 
directory entry 157, entry A 181, entry B 183, entry C 185, entry D 189, 
entry E 191, entry F 193, entry G 197, entry H 199. entry 1 187, and entry J 
195. The child pointers are pointers 159, 161, 165, 169, and 171. The 
sibling pointers are pointers 163, 167, 171, 173, 175, and 179. 

Figure 9 shows the logical arrangement of linked-list directory 
entries. Figure 10 shows the physical location of the linked-list directory 
entries within block 1 34 of flash memory array 112. 

The sibling and child pointer fields of the last directory entry of any 
linked-list chain of directory entries contains the F (hexadecimal) null 
pattern of data, which is all logical ones. This indicates that this directory 
entry is the end of the chain. (An erased directory entry contains in its 
entirely - - i.e., in all its fields - - the F (hexadecimal) null pattern of data). 

Directory entries are added to the linked-list chain each time a file is 
created, moved, or changed. The F (hexadecimal) null pattern of data in 
either the sibling or child pointer field of a last directory entry in a particular 
linked-list chain is overwritten to a new pattern of data that is either a 



38 



respective sibling or child pointer to the newly-created directory entry. This 
overwriting can be done because each single bit cell of the Hash memory 
array can be overwritten from a logical* one to a logical zero. Thus, the 
linked-list chain of directory entries 158 grows and moves into free space 
5 1 60 as files are created, moved, or changed. In other words, free directory 
space 160 provides room for the expansion with time of linked-list directory 
entries 158. 

Each directory entry also has status bits to indicate the validity of its 
file or subdirectory entry. These status bits are overwritten to the zero state 
10 to indicate that the directory entry merely continues the directory linkage, 
but no longer represents an active file or subdirectory. When the status bits 
have been overwritten to the zero state to indicate a mere linkage, the 
directory entry is considered unused space within flash memory array 112. 
Ifff Furthermore, if the directory entry is a file type entry and the status bits are 

15 overwritten to the zero state to indicate that the entry merely continues the 
directory linkage, then the space within flash memory array 112 associated 
with this file type directory entry is considered unused space. 

File system clean-up is required to free this unused space for 
subsequent writes. Because flash memory blocks erase all at once, each 
20 unused directory entry cannot be individually rewritten. Dynamic directory 
relocation helps to overcome this problem. 

During clean-up, the unused directory entries are compressed out. 
New directory linked lists with unused directory entries compressed out 
must effectively start all over from the root directory entry. Dynamic 
25 directory relocation entails reconstructing the new linked list in a separate 
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block. The prior directory block or blocks serves as a backup until a new 
directory tree is constructed. The new directory tree might consist of a new 
directory together with new append directory blocks. In one embodiment of 
the present invention, during the directory construction that is part of 
directory relocation, the new directory is written directly into a reserve 
block of flash memory array 112. For example, the new directory could be 
written into reserve block 116 of flash memory array 112. 

Cleanup involves first moving all currently active files out of blocks 
that will be eventually erased, which is reallocation. The new directory 
reflects both the compression (i.e., removing) of old files and the physical 
relocation within flash memory array 112 of the still active files. In one 
embodiment of the present invention, these transferred files are written 
directly from old flash memory locations to new flash memory locations. 

Block status table 156 is used to keep track of which blocks are free, 
in use, in reserve, or defective. Block status table 156 keeps track of the 
blocks throughout normal file read operations, throughout normal file write 
operations, and during clean-up operations. 

In an alternative embodiment of the present invention, RAM buffering 
is used. With RAM buffering, during a clean-up operation files are written to 
RAM of the personal computer system as an intermediate step before the 
files are written to a new location within flash memory array 1 12. With RAM 
buffering, transferred files are not written directly from old to new locations 
within flash memory array 1 12. Instead, the files pass through RAM of the 
personal computer system. 
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In an alternative embodiment of the present invention, certain 
directory entries additionally include append pointers. An append pointer 
is used to split up an individual data file into two data files, one of the data 
files being in one block and other of the data files being In a different block. 
This allows data files to be split around block boundaries. This allows an 
individual data file to loop from the end to the beginning of physical 
addresses of flash memory array 112. This also allows an Individual data 
file to jump around a defective or bad block. 

In yet another embodiment of the present invention, each directory 
entry for files additionally includes secondary fields for a file name, a suffix, 
and an address. This permits one time renaming, editing, and appending 
files without the necessity of discarding the original directory entry. Suffix 
renaming could be used, for example, when back-up copies are kept when 
data files are edited. 

In an alternative embodiment of the invention, file structure 110 
shown in Figure 8 additionally includes a header. The header resides, for 
example, in block 122. which no longer then is a free block. 

The header is a file that contains information about the directories 
and about flash memory array 112. In one embodiment, the header contains 
information as to the unformatted size of the entire flash memory array 112, 
the formatted size of flash memory array 1 1 2, the total number of blocks 
within flash memory array 112, and detailed device information relating to 
flash memory array 112. In one embodiment of the present invention, the 
detailed device information stored in the header includes erase and write 
voltages; erase and write commands; and erase and write algorithms; 
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individual and full chip maximum cycling specifications; and read, write, 
and erase performance characteristics of flash memory array 112. 

In an alternative embodiment, the header additionally includes 
information as to the location of an alternate header or alternate headers. 

With this alternative embodiment wherein the header is stored in one 
of the blocks of flash memory array 112, for example block 122, the header 
must be periodically refreshed. Periodic refreshing of the header entails 
completely erasing and rewriting the header periodically. This periodic 
refreshing of the header is necessary because the header typically is a 
cold block with respect to the other blocks of flash memory array 112. In 
other words, the header resides in a block that is cycled less frequently 
than the other blocks of flash memory array 112. Therefore, the header must 
be refreshed periodically. 

In order to determine when the header needs to refreshed, the 
number of erase/program cycles of the blocks adjacent to the header and of 
the header are kept track of. A cycle count parameter is stored in the main 
header block. The cycle count represents the number of the erase/write 
cycles of the header and of the blocks adjacent to the header. 

In this alternative embodiment, an alternative (i.e., backup) copy of 
the header is stored in another block of flash memory 112, for example, 
stored in block 124. This alternative header stored in block 124 is 
temporarily used as the header while the refresh operation is occurring. 

In yet another alternative embodiment, the header does not reside 
within flash memory 1 12. Instead, the header resides within a memory array 
on a separate integrated circuit card that is part of a personal computer 
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system. The memory array storing the header would be a *register : number 
accessed" memory array. The header would thus be stored in a separate 
shadow array. 

With this shadow array embodiment, the header would not need to be 
5 refreshed because the header would not reside within flash memory array 
112. It follows that the header would not be a cold block and that the header 
would not need to include a cycle count parameter relating to hot/cold 
cycling. 

Returning to file structure 110 shown in Figure 8, it is to be 
1 0 appreciated that use of a header is optional. One embodiment of the 

present invention avoids the use of a header with the following structure. 

Flash memory 112 has manufacturer and device identification codes stored 

within the memory array. In one embodiment of the present Invention, those 

manufacturer and device identification codes trigger the software of the 
1 5 personal computer system to go to a look-up table that stores header type 

information that can be inferred from those particular manufacturer and 

device identification codes. 

Figure 11 shows file structure 210 of flash memory array 212. File 

structure 210 is a variable sized file structure, which is also referred to as a 
20 variable file structure. 

Blocks 214, 216, and 218 of flash memory array 112 are 

"to-be-reserved" blocks which are also referred to as reserve or reserved 

blocks. Block 220 is a to-be-free block. 
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Block 222, 224, 226, and 228 are free blocks. Block 230 is a 
partially free block, which partially contains data or code and is partially 
free. 

Blocks 232, 233. 236, 238, 240, 242, and 244 together with a portion 
5 of block 230 comprise the active and deleted contiguous variable sized 
files. In one embodiment, blocks 232. 233, 236. 238. 240, 242, and 244 
together with a portion of block 230 also include the active and deleted 
subdirectories. Files 250. 264, 266, 268, 270, 272, and 274 are deleted 
files within blocks 232, 236, 238, 240. 242, and 244. 

10 For the file structure 210 shown in Figure 1 1 . boot record 254. block 

status table 256, linked-list directory entries 258, and free directory entries 
260 are stored in a separate memory 234 that is not part of flash memory 
array 212. That separate memory 234 is. however, included as part of the 
personal computer system that also includes flash memory array 212. 

15 In one embodiment of the invention, separate memory 234 is 

conventional byte-alterable electrically erasable programmable read only 
memory ("EEPROM"). 

In another embodiment of the present Invention, separate memory 
234 is static RAM ("SRAM"). That SRAM 234 is coupled to a battery that is 
20 part of the personal computer system. When external power to the personal 
computer system is removed, the battery that is coupled to SRAM 234 
continues to supply power to SRAM 234. The power applied to SRAM 234 
by the battery allows SRAM 234 to retain data and code even while power 
is removed from the personal computer system. The battery is required 
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because otherwise an SRAM loses all code and data once power is 
removed from SRAM. 

In yet another embodiment of the present invention, memory 234 

consists of an NVRAM. 

In the embodiment shown in Figure 11. memory 234 is EEPROM. No 
directory flag needs to be stored in EEPROM 234 giveathat by definition 
the link-list directory entries 258 are found in memory 234. In other words, 
the current directory is stored in memory 234. 

In one embodiment of the present invention, file structure 210 
includes a header stored within flash memory array 212. The header 
includes information similar to the information contained in the header 
discussed with respect to Figure 8. With respect to file structure 210 of 
Figure 11, the header additionally includes information that states that the 
root directory resides at a fixed location within location 258 of memory 234. 
In other words, the header defines the root directory as residing in a fixed 
physical address space within memory 234. Again, no directory flag Is 
needed. 

As discussed above, flash memory array 212 can only be erased in 
blocks and not on an individual byte basis. In contrast, EEPROM 234 is 
electrically erasable and user rewritable on a byte-by-byte basis. 
EEPROM 234 is thus said to be byte alterable. The fact that EEPROM 234 
is byte alterable means that file names, suffixes, addresses, and pointers 
within linked-listed directory entries 258 can be individually erased, 
rewritten, and changed. Deleted files can be skipped over by making direct 
individual changes to be preceding sibling pointers and child pointers. 
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In the embodiment of file structure 210 shown in Figure 1 1 , each 
directory entry within linked-list directory entries 258 is defined to be nearly 
identical in size to each of the other directory entries within linked-list 
directory entries 258. Deleted directory entries can then be reused as 
5 needed in a random fashion. 

The linked-listed directory entries 258 of Figure 11 are otherwise 
similar to the linked-list directory entries 158 of Figure 8. The linked-listed 
directory entries 258 support index type pointers described above with 
reference to linked-list directory entries 158. 

1 0 Boot record 254 of Figure 1 1 is similar to boot record 1 54 of Figure 8. 

Boot record 254 of Figure 11 contains information as to the particular file 
system type and the particular file system revision. Boot record 254 also 
contains certain file system parameters, including formattable capacity of 
flash memory array 212, reserved block information with respect to flash 

1 5 memory array 21 2, and information relating to the location of the root 
directory within linked-list directory entries 258. 

Block status table 256 of Figure 11 is similar in content to block status 
table 156 of Figure 8. Block status table 256 of Figure 1 1 contains 
information as to which blocks of flash memory array 212 are active blocks, 

20 which blocks are reserve blocks, and which blocks are defective or failed 
blocks. 

The clean-up operation with respect to flash memory array 212 of 
Figure 11 is similar to the clean-up operation with respect to flash memory 
array 1 12 of Figure 8. The clean-up of flash memory array 212 of Figure 1 1 
25 operates in conjunction with block status table 256 and is done in a circular 
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fashion as described above with respect to flash memory array 112 of 
Figure 8. For file structure 210 shown in Figure 11 , blocks 238, 240, 242, 
and 244 are the next blocks to be cleaned up and compressed. 

Free directory space 260 of Figure 1 1 is space within which future 
5 linked-listed directory entries can be expanded into. It is lo be appreciated 
that the directory entries 258 are (1) byte alterable if memory 234 is 
I byte-alterable EEPROM or {2) bit alterable if memory 234 is RAM. 

Figure 12 shows file structure 300 of flash memory array 302. File 
structure 300 includes byte alterable directory entries 366 that are 
10 analogous to hard disk directory entries and floppy disk directory entries. 
The byte alterable directory entries 366 are stored in a separate memory 
: i 360. 

Fiie structure 300 is a variable sized file structure, also referred to as 
W m ^ a variable file structure. 

15 Blocks 322, 324, and 326 of flash memory array 302 are 

"to-be-reserved" blocks, which are also referred to as reserved blocks or 
reserve blocks. Block 328 is a to-be-free block. 

Blocks 330, 304, 306, and 308 are free blocks. Block 310 is a 
partially free block, which partially contains data or code. 
20 Blocks 312, 314, 316, 318, and 320, together with a portion of block 

310, comprise (1) the active and deleted contiguous variable sized files and 
(2) the fixed length active and deleted subdirectory files. The files 340, 342, 
344, 346, 350, and 354 are deleted files within blocks 312, 314, 316, 318, 
and 320. Files 338, 348, and 352 are deleted subdirectory files within 
25 blocks 31 6. 31 8, and 320. 



47 



For file structure 310 shown in Figure 12, boot record 362, btock 
status table 364. and directory entries 366 are stored in a separate memory 
360 that is not part of flash memory array 302. That separate memory 360 is, 
however, included as part of the personal computer system that also 
includes flash memoiy array 302. 

In one embodiment of the present invention, separate memory 360 is 
conventional byte alterable EEPROM. 

In another embodiment, separate memory 360 is SRAM. That SRAM 
360 is coupled to a battery that is part of the personal computer system. 
When external power to the personal computer system is removed, the 
battery that is coupled to SRAM 360 continues to supply power to SRAM 
360. 

In yet another embodiment of the present invention, memory 360 
consists of an NVRAM (i.e., a non-volatile RAM). 

In the embodiment shown in Figure 12, memory 360 is a 
byte-alterable EEPROM. No directory flag needs to be stored in EEPROM 
360 given that by definition the directory entries 366 are found memory 360. 
The current root directories are stored in memory 360. 

In one embodiment, file structure 300 includes a header stored within 
flash memory array 302. The header is similar to the header discussed with 
respect to Figure 8. The header for file structure 300 of Figure 12 also 
includes information that states that the root directory resides at a fixed 
location within location 366 of memory 360. Again, no directory flag is 
needed. 
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Flash memory array 302 can only be erased in blocks and not on an 
individual byte basis, in contrast, EEPROM 360 is electrically erasable and 
user rewritable on a byte-by-byte basis. EEPROM 360 is thus said to be 
byte alterable. The fact that EEPROM 360 is byte alterable means that the 
5 directory entries 366 can be individually erased, rewritten, and changed. 

The directory structure 366 of file structure 300 is analogous to the 
directory structure of a hard disk or a diskette in a personal computer 
system. The directory structure 366 is referred to as a disk analog directory 
structure. 

1 0 The disk analog directory structure 366 results in an operating 

system interface for the personal computer system that is quasi-compatible 
with magnetic hard disk based file structures. For file structure 300, data 
files are created in the main flash memory array 302 to store both directory 
and subdirectory contents. Similarly, on prior magnetic hard disk drives 

1 5 and floppy disk drives for personal computer systems, both directory and 
subdirectory contents are stored on the disks. In addition, directory entries 
366 include structure similar to a file allocation table ("FAT') found within 
the DOS operating system stored on many prior hard disk drives. 

For the embodiment shown in Figure 12, the directory entries 366 are 

20 stored at locations 368, 370, 372, 374. and 376 of memory 360. As 

described in more detail below, the disk analog directory entries 366 differ 
from the linked-listed directory entries 158 and 258 of Figures 8 and 11 
respectively. 

Figure 13 illustrates examples of the structures of the directory entries 
25 366. Figure 13 illustrates directory entries 301 and 361 that are part of 



directory entries 366. Each directory entry is a fixed length - - for example, 
40 bytes. 

Root directory entry 301 includes an eight-byte name 311, a 
three-byte file extension 313, a one-byte attribute flag 315, a ten-byte 
reserved area 317, a two-byte time area 319, a two-byte date 321, a 
two-byte starting cluster 323, a one-byte status of cluster flag 325. a 
four-byte file size area 327, and a two-byte pointer 329. 

The file name and extension bytes 311 and 313 identify the file 
corresponding to root directory 301. 

Attribute flags 315 are comprised of eight-bits 341, 343, 345, 347, 
349, 351 , 353, and 355. Bit 341 (bit 0) marks the files as a read only file, 
which means that the file cannot be edited or erased. Bit 343 (bit 1 ) 
Indicates that the file is hidden to DOS and cannot be read with the 
directory command of DOS and certain other DOS commands. Bit 345 (bit 
2) is the system bit that indicates that the file is a DOS file that cannot be 
read with a directory command and certain other DOS commands. 

Bit 347 (bit 3) Is a volume label. Bit 349 (bit 4) is a subdirectory 
pointer. If either bit 347 or 349 is set, then DOS must handle the entry 
differently from a normal file directory entry. 

If the subdirectory bit 349 is set, this indicates that the directory entry 
is a subdirectory file and that the subdirectory file is stored within one of the 
blocks of flash memory array 302. 

Bit 351 (bit 5) is an archive bit that indicates if the file has been 
backed up by a backup utility. Bit 353 (bit 6) and bit 355 (bit 7) are reserved 
bits that are not used. 
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Reserved bytes 317 are reserved and not used. 

Bytes 319 and 321 are the time and date stamps for the files. 

Bytes 327 indicate the file size or length. 

Bytes 323 and 325 of root directory 301 are the file allocation table 
5 ("FAT) type bits of root directory 301. Starting cluster bytes 323 are the 
file's starting address within flash memory array 302. Byte 325 is referred to 
as the status of cluster byte. The status of cluster byte 325 indicates the 
status of the file that starts at the starting address indicated in bytes 323. 
Status byte 325 indicates whether the file is available, deleted, or defective. 

10 It is to be appreciated that the starting cluster referred to by bytes 323 

is a simulated artificial cluster. The file referred to by file directory entry 301 
is in fact a variable length file. The cluster file structure is simulated by root 
directory 301 in order to have a directory structure that is somewhat 
analogous to the directory structure found on a hard magnetic disk drive 

1 5 (fixed or floppy) upon which DOS is stored. 

If the file size stored within file size bytes 327 is greater than the size 
of starting cluster 323, then a plurality of simulated clusters must be chained 
together in order to completely specify the file. This is done as follows. The 
pointer bytes 329 of root directory 301 point to append directory entry 361 

20 of Figure 13. Append directory entry 361 includes file allocation table 
bytes 383 and 385. Bytes 383 are the cluster bytes. Byte 385 is the status 
of cluster byte. 

Cluster bytes 383 store the starting address within flash memory array 
302 of the data or code that is to be chained with the data or code pointed to 
25 by the address stored in starting cluster bytes 323. Byte 385 of append 
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direCoty 361 Wca.es .he status of .ha file starting a. toe address stored 
w..h by.es 383. The status ofc.us.er bye 385 Wca.es whether the fite ,ha. 
•s stored a. the address stored .n by.es 383 .s available, deleted, or 
defective. 

' » ™ Cher data or code Is to be chained together to form ,he file. ,hen 

power 369 o, directory entry 361 does no. point to any other directory 
entries. 

Because the directory entry 361 is n,ere.y an append directory enfly 
if does no, matter what the contents are o. name bytes 371. extension bytes ' 
373. attribute byte 375. resetved bytes 377. time bytes 379. date byles 381. 
arid file size bytes 387. 

« Is to be appreciated that certain directory entries do not have any 
append fibs. In addi.ion. cartain Cher directory entries have a plutality o. 
append tiles. The pointer o, an append file can point to anotherfile 

R.e strucure 300 takes advantage o, .he byte alterabilky of memory 
360 by using uniform length direCoty enWes to make them easily usable 
by way o. evening. The symmetrica, entty sl.es also allow «ha entries to 
be .reeled as disk conventional file allocation table entries. By using 
FAT-ayle status of caster bytes, status reporting .or We strecture 300 Is 
relatively simple, and resembles the status reporting for conventional ha* 
disk drives storing DOS. 

Parent direcoty entries of memoty 360 refer to combination 
direCoty/FAT index locations as a hard (or floppy, disk uses rts separate 
FAT indices for file references. 
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Each direclory/FAT entry within memory 360 mimics DOS entries by 
referring to a file's starting address as the starting cluster. Artificial clusters 
are chained to this first FAT entry whenever the file length is larger than the 

simulated cluster. 

Boot record 362 stored in memory 360 stores the simulated cluster 
size. Boot record 362 also stores the number of available clusters and the 
maximum number of directory entries. The number of available clusters is 
the formattable capacity of flash memory array 302. Boot record 362 also 
contains information as to the particular file system type and the particular 
file system revision. Boot record 362 also contains certain other file system 
parameters, including reserved block information with respect to flash 
memory array 302, and information relating to the location of the root 
directory within directory entries 366. 

The operating system of the personal computer system sees a 
number of sectors equivalent to the number of directory/FAT entries within 
memory 360 multiplied by the simulated cluster size that is defined on format. 
The number of directory/FAT entries within memory 360 is equal to the size 
of the combined area 368, 370. 372. 374, and 376 divided by the size of the 

directory entries. 

Block status table 364 of Figure 12 is similar in contents to block 
status table 156 of Figure 8. Block status table 364 of Figure 12 contains 
information as to which blocks of flash memory array are active blocks, 
which blocks are reserved blocks, and which blocks are defective or failed 
blocks. 
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The clean-up operation with respect to flash memory array 302 of 
Figure 12 is similar to the clean-up operation with respect to flash memory 
array 112 of Figure 8. The clean-up of flash memory array 302 of Figure 12 
operates in conjunction with block status table 364 and is done in a circular 
fashion as described above with respect to flash memory array 112 of 
Figure 8. For file structure 300 shown in Figure 12, blocks 316, 318, and 
320 are the next blocks to be clean-up and compressed. 

The personal computer system must track the directory and main 
flash memory 302 utilization to know where the next available space is for 
each new entry. This is an actively calculated process given the lack of 
disk-like sectors. 

The size of the directory entries 366, the boot record 362, and the 
block status table 364 cannot expand beyond the size of memory 360. 
Nevertheless, subdirectory files can be stored within flash memory array 
302. 

Due to the inability to generally overwrite flash memory information, 
the directory files 366 must preallocate space for a fixed number of entries, 
and then point to an append for additional entries. 

Figure 14 shows file structure 400 of flash memory array 401. File 
structure 400 is a file structure that includes sectors and a dynamic flash 
directory. File structure 400 is also referred to as a sectored file structure. 

In a sectored file structure such as file structure 400, code or data is 
stored in sectors. The sectors are analogous to sectors on prior art hard 
disks and diskettes of a personal computer system. On a prior art hard disk, 
there are typically 17 sectors per track. For some hard disks, there are four 
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sectors per cluster. For some other other hard disks and for a high density 
3.5 inch diskette, a cluster comprises a single sector. A cluster is a smallest 
logically addressable stored unit. 

For file structure 400. a cluster is made up of a single sector. Each 
sector is 512 bytes wide, which is a fixed length. Each cluster is also 
referred to as an allocation unit ("AU"). 

In an alternative embodiment of the present invention, each cluster is 
made up of two sectors. In yet another alternative embodiment, each cluster 
is made up of three or more sectors. 

The sectored file structure of file structure 400 helps to simplify 
software or firmware driver based emulation of conventional disk file 
structures. This is because the sectored file structure of file structure 400 is 
similar to the sectored file structure found on hard disk drives. 

Sectored file structure of file structure 400 also allows random 
selection of erase blocks for clean-up. This in turn helps to reduce file 
movement when such file movement is unnecessary. This also helps to 
reduce excess cycling. 

On the other hand, a sectored file structure cannot support complete 
contiguous execution in place of code files. Nevertheless, contiguous 
sector-paged memory file schemes allow large contiguous portions or 
smaller code files to execute in place. 

For a sectored file structure, the cycling of individual blocks must be 
tracked to support the active management of hot/cold erase block 
redistribution during clean-up. This cycling of individual blocks is 
intrinsically managed by the clean-up/reallocation rules discussed below. 
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Blocks 416. 424, and 428 of flash memory array 401 
"to-be-reserved" blocks, which are also referred to as reserve blocks or 
reserved blocks. Block 408 Is a to-be-free block, which becomes a free 
block after the next clean-up operation. 

Blocks 404, 414, and 420 of flash memory array 401 are free blocks, 
which are usable blocks for storing code and data. Block 430 is a partially 
free block, which contains data or code at location 464 and which has free 
space at allocation 462. 

The sectors within blocks 402, 406* 412, 418, and 426, together with 
the sectors within portion 464 of block 430, comprise the active and deleted 
files and subdirectories. Sectors 403, 405, 409, 411, 413, 415. 417. 423, 
425, and 427 within block 402 and sectors 431. 433, 439, 443, 445. and 
453 within block 406 are examples of active file and subdirectory sectors. 
Blocks 412, 418, 426, and 430 also include active file and subdirectory 
sectors. Sectors 407, 419, 421. 429. 435. 437. 441, 447. 449, 451, 457. 
459. 461. 463, 465, 467. 469. 471. 473, 475. 477. 479. 481, 483. 485. 
487, 489, and 491 are the sectors containing deleted files and 
subdirectories. * 

Through the use of file allocation table 446, the clusters of file 
structure 400 are logically concatenated in order to form a complete file. 
This is similar to what is done in a prior conventional personal computer 
system with a fixed disk drive or a floppy disk drive, wherein the clusters of 
the fixed disks or floppy disk are logically concatenated to form a completer 
file. 
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In Figure 14, file allocation table 446, is stored within block 422. File 
allocation table 446 is part of the dynamic directory scheme used by file 
structure 400. Block 422 includes directory flag 440. boot record 442. 
block status table 444. FAT 446. linked-list directory entries 448. and free 
5 space 450. Block 422 thus contains the current directory. 

Directory flag 440 stores a pattern of data that indicates that block 
422 contains the linked-list directory entries 448. 

Boot record 442 follows directory flag 440. Boot record 442 contains 
information as to the particular file system type and the particular file system 
revision. Boot record 442 also contains certain file system parameters. 
Those parameters include formattable capacity information, reserved block 
information, appended directory information, information relating to the old 
directory, and information relating to the root directory. 

Block status table 444 follows boot record 442. Block status table 
444 contains information as to which blocks are active blocks, which blocks 
are reserve blocks, and which blocks are defective or failed blocks. Block 
status table 444 also contains cycle count information for each block. The 
cycle count information indicates how many times a block has been erased 
and rewritten to. 

File allocation table 446 follows block status table 444 in block 422. 
File allocation table 446 resides before the root directory found within 
linked-list directory entries 448. 

Linked-list directory entries 448 are also referred to as main directory 
448. Main directory 448 contains a series of individual directory entries. 
Each directory entry is either (1) a pointer to a subdirectory (the 
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subdirectory being stored in a biock other than block 422) or (2) a directory 
for a file. The directory entries 448 of Figure 14 resemble the directory 
entries 158 of Figure 8 except that FAT pointers 446 are used in file 
structure 400 in place of physical main-memory starting addresses. Each 
5 directory file entry of Figure 1 4 includes information as to the file 

name/extension, the date, the time, the file type, the file length, a sibling 
pointer, and a child pointer. Each directory file entry also includes a cluster 
number that is the number of the first cluster used in a particular file. The 
cluster number is two bytes in size. In one embodiment, file allocation table 

* 

1 0 446 is a list of two byte entries, one for each cluster. The operating system 
for file structure 400 uses the first cluster number to access file allocation 
table 446. The FAT entiy for that cluster contains the cluster number of the 
next cluster in the file. Each FAT 446 entry is a pointer to the next cluster of 
the file. The operating system uses this to access the next cluster of the file 

1 5 and then continues until a special marker in the FAT 446 is reached. In one 
embodiment of the present invention, that special marker is F null in 
hexadecimal. If the FAT 446 entry is zero, this indicates that the cluster is 
not in use. 

For file structure 400 of Figure 14, each FAT entry of FAT 446 has a 
20 one-to-one correspondence to a physical cluster of flash memory array 401 
and points to chained FAT entries until the last file allocation cluster is 
reached. The last FAT entry is indicated by F (hexadecimal) null data, 
which is data that is still erased - i.e., all ones. 

The directory entries for file structure 460 of Figure 14 resemble the 
25 directory entries for file structure 1 10 of Figure 8 except that for file structure 
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400 of Figure 14 FAT pointers are used in place of physical main memory 
starting addresses. For file structure 400 of Figure 14, non-contiguous file 
information is concatenated by disk-like FAT chaining. 

One of the ways in which file structure 400 differs from that of a fixed 
5 disk or a floppy disk is that child and sibling pointers are used within 
linked-list directory entries 448. 

The FAT entries and the main-memory clusters themselves are 
symmetrical in length, and both consist of shortened index-type addresses. 
The maximum number of FAT entries is fixed, determining the formattable 
1 0 capacity for a given cluster size (i.e., number of sectors per AU) and the 
number of reserve blocks. This is recorded in boot record 442 upon 
formatting. 

In addition to "free," "reserve", and "bad" status, block status table 
444 contains cycle count information on each block. Block status table 444 

15 reserves the directory block(s) and reserve blocks as inaccessible (to allow 
subsequent clean-up), preventing the file system from attempting to 
overwrite these blocks. Failed blocks are also avoided and are indicated in 
block status table 444. 

Clusters are generally written contiguously through the end a given 

20 free blocks, then concatenated to subsequent clusters written into another 
free block. This normally-consecutive cluster usage can support paged 
execute-in-place operation for appropriately-specified code files. 
Subsequent file deletion creates random unused portions throughout the 
main flash memory array. 
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When clean-up is required, the personal computer system identifies 
. which blocks are to be cleared for a subsequent rewrite. In other words, 
upon clean-up the computer system identifies the blocks having files that 
are to be reallocated and moved upon clean-up. The Identification of 
5 blocks to be cleared upon clean-up is governed by two rules. The first rule 
is that the least cycled block is selected. This reduces the cycling 
imbalances between hot and cold blocks. 

If there are not large disparities between cycle counts of blocks, then 
the second rule governs. In other words, where cycling distribution is not 

1 0 flagged as a problem by the computer system, the second rule governs. 
The second rule states that the btocks with the highest number of deleted 
sectors are the blocks that are selected to be cleared. 

The reason for this second rule is that the clusters containing deleted 
files do not need to be moved out of a block prior to erasure. The deleted 

1 5 files contain no information that must be save, the deleted files can be 

erased as part of a clean-up operation. In other words, there needs to .be no 
reallocation of deleted files. The second rule thus results In a minimal 
1 amount of moving out of active sectors or clusters prior to the erasure that is 
part of a clean-up operation. 

20 It is essentially a random process that governs which blocks contain 

the most deleted file clusters. Therefore, the second rule means that the 
clean-up scheme results in a largely random block selection with respect to 
the blocks to be cleared. This essentially random block selection helps to 
increase the clean-up efficiency while, at the same time, minimize overall 

25 cycling disparities. 
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The above rules one and two together manage the cycling 
distributions within flash memory array 401 . Rules one and two together 
help to minimize cycling differentials. It follows that the clean-up of file 
structure 400 Is essentially random. 

For file structure 400 of Figure 14, a new directory (and new append 
directory), along with a new FAT, are constructed In a reserve block upon 
clean-up. 

In one embodiment, file structure 400 includes a header stored within 
flash memory array 401. The header includes Information similar to the 
information contained in the header discussed with respect to file structure 
110 of Figure 8. 

Figure 15 shows file structure 500 of flash memory array 501. File 
structure 500 is a file structure that includes sectors, and is referred to as a 
sectored file structure. 

In sectored file structure 500, data or code is stored in sectors. In the 
embodiment of Figure 15, there is one sector per cluster, and each sector is 
512 bytes. 

Blocks 508, 516, and 524 are the reserve blocks of file structure 500. 
Block 508 is a to-be-free block. 

Blocks 504, 514, and 520 are free blocks. Block 5301s a partially 
free block, which contains data or code at location 564 and which has free 
space at location 562. 

The sectors within blocks 502, 506, 512, 518, and 526, together with 
the sectors within portion 564 of block 530, comprise the active and deleted 
files and subdirectories. Sectors 503, 505, 509. 511, 513, 515, 517, 523, 
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525. and 527 within block 502 and sectors 531, 533, 539. 543. 545, and 
553 within block 506 are examples of active file and subdirectory sectors. 
Blocks 512. 518. 526. and 530 also include active file and subdirectory 
sectors. Sectors 507. 519, 521, 529, 535, 537, 541, 547, 549. 551, 557, 
559. 561. 563, 565. 567, 569. 571, 573. 575. 577. 579. 581, 583, 585, 
587, 589, and 591 are the sectors containing deleted files and 
subdirectories. 

For file structure 500 shown in Figure 15, boot record 542, block 
status table 544, file allocation table 546, linked-list directory entries 548, 

4 

and free directory space 550 are stored in a separate memory 534. That is 
not part of flash memory array 501. The separate memory 534 is, however, 
included as part of the personal computer system that also includes flash 
memory array 501. 

In one embodiment of the invention, separate memory 534 is 
conventional byte-alterable EEPROM. 

In another embodiment, separate memory 534 Is an SRAM coupled to 
a battery as a back-up. 

In yet another embodiment, separate memory 534 is an NVRAM. 

In the embodiment shown in Figure 15, memory 534 is an EEPROM. 
No directory flag needs to be stored in EEPROM 534 given that by 
definition the linked-list directory entries 548 are found in memory 534. In 
other words, the current directory is stored in memory 534. 

In one embodiment, file structure 500 includes a header stored within 
flash memory array 501. The header stores information similar to the 
information contained in the header discussed with respect to Figure 8. 
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File structure 500 of Figure 15 resembles file structure 400 of Figure 
14, except that file structure 500 has directory entires 548 at a fixed location 
in separate memory 534. This means that file structure 500 has no directory 
flag with respect to memory 534 and that there are a maximum number of 
directory entries. 

To simplify random link-list directory modification, directory entries 
548 are again symmetrical in length. The block status table 544 is used for 
cycling management during random, relatively efficient block reallocation. 
All other directory/FAT operations resemble those of file structure 400 of 
Figure 14. 

Figure 16 shows file structure 600 of flash memory array 601. File 
structure 600 is a file structure that includes sectors, and is referred to as a 
sectored file structure. 

tn sectored file structure 600. data or code is stored in sectors. In the 
embodiment of Figure 16. there is one sector per cluster, and each sector is 
512 bytes. 

Blocks 608, 616, and 624 are the reserve blocks of file structure 600. 
Block 608 is a to-be-free block. 

Blocks 604, 614. and 620 are free blocks. Block 630 is a partially 
free block, which contains data or code at location 664 and which has free 
space at location 662. 

The sectors within blocks 602, 606, 61 2. 61 8. and 626, together with 
the sectors within portion 664 of block 630. comprise the active and deleted 
files and subdirectories. Sectors 603. 605. 609, 611, 613, 615. 617, 623. 
625. and 627 within block 602 and sectors 631, 633, 639. 643, 645, and 
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653 within block 606 are examples of active file and subdirectory sectors. 
Blocks 612, 618. 626, and 630 also include active file and subdirectory 
sectors. Sectors 607, 619, 621, 629, 635, 637, 641, 647, 649, 651, 657, 
659, 661. 663. 665, 667. 669. 671, 673. 675, 677, 679. 681. 683. 685. 
5 687, 689, and 691 are the sectors containing deleted files and 
subdirectories. 

For file structure 600 shown in Figure 16, boot record 642, block 
status table 644. file allocation table 646, and directory entries 648 are 
stored in a separate memory 634 that is not part of flash memory array 601 . 
1 0 The separate memory 634 is, however, included as part of the personal 
computer system that also includes flash memory array 601. 

In one embodiment of the invention, separate memory 634 is 
conventional byte-alterable EEPROM. 

In another embodiment, separate memory 634 is an SRAM coupled to 
15 a battery as a back-up. 

In yet another embodiment, separate memory 634 is an NVRAM. 
In the embodiment shown in Figure 16. memory 634 is an EEPROM. 
No directory flag needs to be stored in EEPROM 634 given that by 
definition the directory entries 648 are found in memory 634. In other words, 
20 the current directory is stored in memory 634. 

In one embodiment, file structure 600 includes a header stored within 
flash memory array 601. The header stores information similar to the 
information contained in the header discussed with respect to Figure 8. 
File structure 600 of Figure 16 resembles file structure 400 of Figure 
25 14, except that file structure 600 (1) has a directory structure 648 that is 



analogous to the directory structure of a hard disk or a diskette in a personal 
computer system and (2) stores directory entries 648 in a separate memory 
634. File structure 600 has no directory flag with respect to memory 634. 

File structure 600 of Figure 16 thus has a disk-analog directory 
structure. This implementation simply follows magnetic disk directory and 
FAT conventions. Byte alterability allows direct overwriting the directory 
and FATs sector use/chaining Information. The primary flash-specific 
aspect is that the logical sectors can be overwritten only after first erasing at 
the erase block-level. Thus the subdirectory file entry schemes and most 
other constraints and characteristics resemble file structure 300 of Figure 
12 although clean-up follows the conventions of file structure 110 of Figure 
8. File structure 600 of Figure 16 operates in a manner analogous to 
conventional magnetic disk operation, with reading and writing file and 
subdirectory clusters that are similar to disk clusters. The use of block 
status table 644 and the clean-up operations are the key flash-specific 
elements. In a preferred embodiment, "backup directory/FAT" approach 
typical of conventional disks is employed. 

The preferred embodiments of the present Invention help to improve 
device reliability due to intrinsic flash cycling management. The preferred 
embodiments of the present invention also help to improve file system 
reliability due to intrinsic backup copy provisions - - i.e., avoiding 
overwriting of active file and/or directory information. 

The preferred embodiments of the present invention minimize system 
RAM requirements by (1) embedding control code in firmware, and (2) using 
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reserve blocks for direct block-to-block file and directory transfer during 
clean-up. 

Preferred embodiments of the present Invention minimize waste of 
flash memory space through the use of linked-list directory structures. 
5 Variable-file embodiments of the present invention allow for 

reallocation via clean-up of small, manageable portions of the flash array. 

In the embodiment employing a sectored/dynamic directory helps to 
improve performance, reliability, and efficiency given the use of the block 
status table. The block status table supports (1) uniform flash device and 
1 0 block cycling to maximize device reliability while helping to prevent hot 
spots from causing erase and write performance degradation relative to 
other devices and blocks within devices (when they exist) and (2) the 
tracking of reserve blocks for fast, reliable clean-up and "background-task" 
erasure. 

15 In the foregoing specification, the invention has been described with 

reference to specific exemplary embodiments thereof. It will, however, be 
evident that various modifications and changes may be made thereof 
without departing frorri the broader spirit and scope of the invention as set 
forth in the appended claims. The specification and drawings are, 

20 accordingly, to be regarded in an illustrative rather than a restrictive sense. 
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CLAIMS 

1. A non-volatile semiconductor memory that is erasable only in 
blocks, wherein each bit of the non-volatile semiconductor memory cannot 
be overwritten from a first logical state to a second logical state without a 
prior erasure, and wherein each bit of the non-volatile semiconductor 
memory can be overwritten from a second logical state to a first logical state 
without a prior erasure, comprising: 

(A) an active block for storing a first file; 
\ (B) a reserve block for storing a second file, wherein the 
second tile is a copy of the first file, wherein the copy is made during 
a clean-up operation prior to an erasure of the active block; 

(C) a directory block comprising a directory entry for 
identifying the first file. 

2. The non-volatile semiconductor memory of claim 1, wherein 
the active and reserve blocks have a variable-length file structure. 

3. The non-volatile semiconductor memory of claim 1, wherein 
the active and reserve blocks have a sectored file structure. 

4. The non-volatile semiconductor memory of claim 1, wherein 
the first logical state is a logical zero and the second logical state is a 
logical one. 

5. The non-volatile computer semiconductor of claim 1, wherein 
the memory is a electrically flash erasable programmable read-only 
memory. 
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6. The non-volatile semiconductor memory of claim 1, wherein 
the directory block further comprises: 

(A) a flag for identifying the directory block as a directory 

block; 

(B) a boot record concerning information concerning a file 
structure of the semiconductor memory; 

(C) a block status table for providing information as to 

(1) whether a block is 

(i) an active or a reserve block; 

(ii) free or in use; and 

(iii) defective or not defective; and 

(2) how many times a block has been erased and 

rewritten to. 

7. The non-volatile semiconductor memory of claim 6, wherein 
the information contained with the boot record comprises: 

(A) the file structure type; 

(B) formattable capacity of the file structure; 

(C) an address of the directory entry. 

8. The non-volatile semiconductor memory of claim 1, further 
comprising a header containing information comprising: 

(A) an unformatted size of the semiconductor memory; 

(B) a maximum number of erase cycles recommended for 
the semiconductor memory; 

(C) erase and write voltages; 
(0) erase and write commands; 
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(E) erase and write algorithms. 

9. A memory system for a computer, comprising: 

(A) a non-volatile semiconductor memory that is erasable in 
blocks, wherein each bit of the non-volatile semiconductor memory 
cannot be overwritten from a first logical state to a second logical 
state without a prior erasure, and wherein each bit of the non-volatile 
semiconductor memory can be overwritten from a second logical 
state to a first logical state without a prior erasure, comprising: 

(1) an active block for storing a first plurality of files; 

(2) a reserve block for storing a second plurality of 
files, wherein the second plurality of files are copies of the first 
plurality of files, wherein the copies are made during a clean-up 
operation prior to an erasure of the active block; 

(B) a memory for storing a plurality of directory entries, 
wherein each directory entry identifies a respective file of the first 
plurality of files. 

10. The memory system of claim 9, wherein the active and reserve 
blocks have a variable-length file structure. 

11. The memory system of claim 9, wherein the active and reserve 
blocks have a sectored file structure. 

1 2. The memory system of claim 9, wherein 

(A) the non-volatile semiconductor memory is a flash 
electrically erasable programmable read-only memory, 

(B) the first logical state is a logical zero, and 

(C) the second logical state is a logical one. 
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1 3. The memory system of claim 9, wherein the plurality of 
directory entries comprise a linked-fist. 

1 4. The memory system of claim 9, wherein the plurality of 
directory entries comprise a hierarchical directory structure that is byte 
alterable. 

1 5. The memory system of claim 9, wherein the memory for storing 
a plurality of directory entries is a byte-alterable electrically erasable 
programmable read-only memory. 

1 6. The memory system of claim 9, wherein the memory for storing 
a plurality of directory entries is a random-access memory. 

1 7. The memory system of claim 9, wherein the memory for storing 
a plurality of directory entries further comprises: 

(A) a boot record containing information concerning a file 
structure of the non-volatile semiconductor memory; 

(B) a block status table for providing information as to 
whether a block of the non-volatile semiconductor memory is 

(1 ) an active block or a reserve block, 

(2) free or in use, and 

(3) defective or not defective. 

1 8. The memory system of claim 1 1 , wherein the memory for 
storing a plurality of directory entries further comprises: 

(A) a boot record containing information concerning a file 
structure of the non-volatile semiconductor memory; 

(B) a block status table for providing information as to 
whether a block of the non-volatile semiconductor memory is 
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(1) an active block or a reserve block, 

(2) free or in use, and 

(3) defective or not defective; and 
(C) a file allocation table. 

19. A flash electrically erasable programmable read-only memory 

(EEPROM), comprising: 

(A) an active block for storing a first plurality of files; 

(B) a reserve block for storing a second plurality of files, 
wherein the second plurality of files are copies of the first plurality of 
files, wherein the copies are made during a clean-up operation prior 
to an erasure of the active block; 

(C) a directory block comprising: 

(1 ) a flag for identifying the directory block as a 

directory block; 

(2) a boot record containing information concerning 

the file structure of the flash EEPROM; 

(3) a block status table for providing information as to 
whether a block is (a) an active block or a reserve block, (b) free or 
in use, and (c) defective or not defective; 

(4) a plurality of linked-list directory entries, wherein 
each directory entry identifies a respective file of the first plurality of 
files. 

20. The flash EEPROM of claim 1 9, wherein the plurality of linked 
directory entries comprise at least one root directory and at least one 
pointer to a subdirectory stored as a file. 
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21 . The flash EEPROM of claim 1 9, wherein each of the plurality 
of linked-list directory entries further includes information comprising: 

(A) entry type for indicating whether the directory entry for a 
respective file of the first plurality of files is a root directory entry or a 
pointer to a subdirectory; 

(B) if the directory entry is a root directory entry, then the 
directory entry further includes information comprising: 

(1) a name of the file; 

(2) a date and time stamp for the file; 

(3) file type information that indicates whether the file 
comprises code or data; 

(4) a length of the file; 

(5) an address of the file; 

22. The flash EEPROM of claim 21 , wherein the plurality of linked 
directory entries further comprise: 

i 

/ 

(A) at least one first pointer to an address of a sibling 
directory entry; and 

(B) at least one second pointer to an address of a child 
directory entry. 

23. The flash EEPROM of claim 22, wherein 

(A) the address of the sibling directory entry pointed to by 
the first pointer is a first offset address within the directory block and 

(B) the address of the child directory entry pointed to by the 
second pointer is a second offset address within the directory block. 

24. The flash EEPROM of claim 22, wherein 
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(A) the address of the sibling directory entry pointed to by 
the first pointer is a first absolute address within the flash EEPROM 
and 

(B) the address of the child directory entry pointed to by the 
second pointer is a second absolute address within the flash 
EEPROM. 

25. The flash EEPROM of claim 19, wherein the information 
contained within the boot record comprises: 

(A) the file structure type; 

'(B) formattable capacity of the file structure; 

(C) an address of a first directory entry of the plurality of 
linked directory entries. 

26. The flash EEPROM of claim 19, further comprising a header 
containing information comprising: 

(A) an unformatted size of the computer memory; 

(B) a maximum number of erase cycles recommended for 
the computer memory; 

(C) erase and write voltages; 

(D) erase and write commands; 

(E) erase and write algorithms. 

27. A computer system comprising: 

(A) a central processing unit; 

(B) a non-volatile semiconductor memory that is erasable in 
blocks, wherein each bit of the non-volatile memory cannot be 
overwritten from a first logical state to a second logical state without a 
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prior erasure, and wherein each bit of the non-volatile semiconductor 
memory can be overwritten from a second logical state to a first 
logical state without a prior erasure, comprising: 

(1 ) an active block for storing a first file; 

(2) a reserve block for storing a second file, wherein 
the second file is a copy of the first file, wherein the copy is made 
during a clean-up operation prior to an erasure of the active block; 

(3) a directory block comprising a directory entry for 
identifying the first file. 

'(C) storage means for storing code for controlling the 
non-volatile semiconductor memory. 

28. The computer system of claim 27, wherein 

(A) the non-volatile semiconductor memory is a flash 
electrically erasable programmable read-only memory, 

(B) the first logical state is a logical zero, and 

(C) the second logical state is a logical one. 

29. The computer system of claim 27, wherein the storage means 
is a read-only 1 memory. 

30. The computer system of claim 27, wherein the storage means 
is a random-access memory. 

31 . The computer system of claim 30, wherein the random-access 
memory is a general purpose system random-access memory. 

32. The computer system of claim 30, wherein the random-access 
memory is a buffer memory. 
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33. The computer system of claim 27, wherein the non-volatile 
semiconductor memory is paged memory mapped. 

34. The computer system of claim 27, wherein the non-volatile 
semiconductor memory is direct memory mapped. 

35. The computer system of claim 27, further comprising a 
hardware controller for executing the code for controlling the non-volatile 
semiconductor memory. 

36. A computer system comprising: 
(A) a central processing unit; 

'(B) a non-volatile semiconductor memory that is erasable in 
blocks, wherein each bit of the non-volatile semiconductor memory 
cannot be overwritten from a first logical state to a second logical 
state without a prior erasure, and wherein each bit of the non-volatile 
semiconductor memory can be overwritten from a second logical 
state to a first logical state without a prior erasure, comprising: 

(1 ) an active block for storing a first plurality of files; 

(2) a reserve block for storing a second plurality of 
files, wherein the second plurality of files are copies of the first 
plurality of files, wherein the copies are made during a clean-up 
operation prior to an erasure of the active block; 

(C) a memory for storing a plurality of directory entries, 
wherein each directory entry identifies a respective file of the first 
plurality of files. 

(D) storage means for storing code for controlling the 
non-volatile semiconductor memory. 
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37. The computer system of claim 36, wherein 

(A) the non-volatile semiconductor memory is a flash 
electrically erasable programmable read-only memory; 

(B) the first logical state is a logical zero; and 

(C) the second logical state is a logical one. 

38. The computer system of claim 36, wherein the storage means 
is a read-only memory. 

39. The computer system of claim 36, wherein the storage means 
is random-access memory. 

40. "The computer system of claim 39, wherein the random-access 
memory is a general purpose system random access memory. 

41 . The computer system of claim 39, wherein the random-access 
memory is a buffer memory. 

42. The computer system of claim 36, wherein the non-volatile 
semiconductor memory is paged memory mapped. 

43. The computer system of claim 36, wherein the non-volatile 
semiconductor memory is direct memory mapped. 

44. The computer system of claim 36, further comprising a 
hardware controller for executing the code for controlling the non-volatile 
semiconductor memory. 

45. A non-volatile semiconductor memory substantially as 
described with reference to the accompanying drawings. 

46. A memory system for a computer, substantially as described 
with reference to the accompanying drawings. 

47. A flash electrically erasable programmable read-only memory 
substantially as described with reference to the accompanying drawings. 

48. A computer system, substantially as described with 
reference to the accompanying drawings. 
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